<template>
    <div style="padding: 6px">
        <el-card style="margin-bottom: 6px">
            <el-form :model="queryParams" ref="queryForm" :inline="true" label-width="60px" style="margin-bottom: -20px">
                <el-form-item label="设备ID" prop="deviceSipId">
                    <el-input v-model="queryParams.deviceSipId" placeholder="请输入设备编号" clearable size="small" @keyup.enter.native="handleQuery" />
                </el-form-item>
                <el-form-item label="通道ID" prop="channelSipId">
                    <el-input v-model="queryParams.channelSipId" placeholder="请输入通道ID" clearable size="small" @keyup.enter.native="handleQuery" />
                </el-form-item>
                <el-form-item label="状态" prop="status">
                    <el-select v-model="queryParams.status" placeholder="请选择状态" clearable size="small">
                        <el-option v-for="dict in dict.type.sip_gen_status" :key="dict.value" :label="dict.label" :value="dict.value" />
                    </el-select>
                </el-form-item>
                <el-form-item>
                    <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
                    <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
                </el-form-item>
                <el-form-item style="float: right">
                    <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" v-hasPermi="['iot:video:add']" :disabled="isGeneralUser">批量生成</el-button>
                    <el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple || isGeneralUser" @click="handleDelete" v-hasPermi="['iot:video:remove']">批量删除</el-button>
                </el-form-item>
            </el-form>
        </el-card>

        <el-card style="margin-bottom: 5px">
            <el-table v-loading="loading" :data="sipidList" @selection-change="handleSelectionChange" @cell-dblclick="celldblclick" size="">
                <el-table-column type="selection" :selectable="selectable" width="55" align="center" />
                <el-table-column label="设备编号" align="center" prop="deviceSipId">
                    <template slot-scope="scope">
                        <el-link :underline="false" type="primary" @click="handleViewDevice(scope.row.deviceSipId)">{{ scope.row.deviceSipId }}</el-link>
                    </template>
                </el-table-column>
                <el-table-column label="通道ID" align="center" prop="channelSipId" />
                <el-table-column label="状态" align="center" prop="status" width="80">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.sip_gen_status" :value="scope.row.status" size="mini" />
                    </template>
                </el-table-column>
                <el-table-column label="所属产品" align="center" prop="productName" />
                <el-table-column label="设备类型" align="center" prop="deviceType">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.video_type" :value="scope.row.deviceType" />
                    </template>
                </el-table-column>
                <el-table-column label="通道类型" align="center" prop="channelType">
                    <template slot-scope="scope">
                        <dict-tag :options="dict.type.channel_type" :value="scope.row.channelType" />
                    </template>
                </el-table-column>
                <el-table-column label="行政区域" align="center" prop="citycode" />
                <el-table-column label="注册时间" align="center" prop="registerTime" width="180">
                    <template slot-scope="scope">
                        <span>{{ parseTime(scope.row.registerTime, '{y}-{m}-{d} {h}:{m}:{s}') }}</span>
                    </template>
                </el-table-column>
                <!-- <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
                <template slot-scope="scope">
                    <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row,'remark')" v-hasPermi="['iot:video:edit']">修改
                    </el-button>
                    <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" v-hasPermi="['iot:video:remove']" v-if="!scope.row.deviceSipId">删除
                    </el-button>
                </template>
            </el-table-column> -->
            </el-table>
            <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />
        </el-card>

        <el-dialog :title="title" :visible.sync="open" width="450px" append-to-body :close-on-click-modal="false">
            <el-form :model="createForm" :rules="createFormrules" label-width="80px" ref="createForm">
                <el-form-item label="行政区划" prop="city">
                    <el-cascader :options="cityOptions" v-model="createForm.city" @change="changeProvince" change-on-select style="width: 330px" :props="{ checkStrictly: false }"></el-cascader>
                </el-form-item>
                <el-form-item label="设备类型" prop="deviceType">
                    <el-select v-model="createForm.deviceType" placeholder="请选择设备类型" style="width: 330px">
                        <el-option v-for="dict in dict.type.video_type" :key="dict.value" :label="dict.label" :value="dict.value"></el-option>
                    </el-select>
                </el-form-item>
                <el-form-item label="通道类型" prop="channelType">
                    <el-select v-model="createForm.channelType" placeholder="请选择设备类型" style="width: 330px">
                        <el-option v-for="dict in dict.type.channel_type" :key="dict.value" :label="dict.label" :value="dict.value"></el-option>
                    </el-select>
                </el-form-item>
                <el-form-item label="所属产品" prop="productName">
                    <el-input readonly v-model="createForm.productName" placeholder="请选择产品">
                        <el-button slot="append" @click="selectProduct()">选择</el-button>
                    </el-input>
                </el-form-item>
                <el-form-item label="通道数量" prop="createNum">
                    <el-input-number controls-position="right" v-model="createForm.createNum" :min="1" :max="10" placeholder="请输入生成通道数量" type="number" style="width: 330px" />
                </el-form-item>
            </el-form>
            <div slot="footer" class="dialog-footer">
                <el-button type="primary" @click="submitForm">生 成</el-button>
                <el-button @click="cancel">取 消</el-button>
            </div>
        </el-dialog>

        <!-- 选择产品 -->
        <product-list ref="productList" :productName="createForm.productName" @productEvent="getProductData($event)" />
    </div>
</template>

<style>
.createNum {
    width: 300px;
}

.createNum input {
    width: 260px;
}
</style>

<script>
import { getDeviceBySerialNumber } from '@/api/iot/device';
import { regionData, CodeToText } from 'element-china-area-data';
import { listChannel, getChannel, delChannel, addChannel } from '@/api/iot/channel';
import productList from './product-list.vue';

export default {
    name: 'Sip',
    dicts: ['sip_gen_status', 'video_type', 'channel_type'],
    components: {
        productList,
    },
    props: {
        product: {
            type: Object,
            default: null,
        },
    },
    watch: {
        // 获取到父组件传递的productId后，刷新列表
        product: function (newVal, oldVal) {
            this.productInfo = newVal;
            if (this.productInfo && this.productInfo.productId != 0) {
                this.queryParams.productId = this.productInfo.productId;
                this.deviceParams.productId = this.productInfo.productId;
                this.getList();
            }
        },
    },
    data() {
        return {
            // 是否普通用户
            isGeneralUser: true,
            // 遮罩层
            loading: true,
            // 选中数组
            ids: [],
            // 非多个禁用
            multiple: true,
            // 总条数
            total: 0,
            // sipid表格数据
            sipidList: [],
            // 弹出层标题
            title: '',
            // 是否显示弹出层
            open: false,
            // 查询参数
            queryParams: {
                pageNum: 1,
                pageSize: 10,
                deviceSipId: null,
                deviceChannelId: null,
                status: null,
            },
            // 表单参数
            createForm: {
                city: '',
                deviceType: '',
                channelType: '',
                createNum: 1,
                remark: '',
                area: '',
            },
            form: {},
            // 产品
            productInfo: {},
            // 城市
            cityOptions: regionData,
            city: '',
            // 表单校验
            //createForm表单校验
            createFormrules: {
                city: [{ required: true, message: '行政区划不能为空', trigger: 'change' }],
                deviceType: [{ required: true, message: '设备类型不饿能为空', trigger: 'change' }],
                channelType: [{ required: true, message: '通道类型不能为空', trigger: 'change' }],
                productName: [{ required: true, message: '产品类型不能为空', trigger: 'blur' }],
                createNum: [{ required: true, message: '请输入生成通道数量', trigger: 'change' }],
            },
            rules: {
                protocol: [
                    {
                        required: true,
                        message: '默认播放协议不能为空',
                        trigger: 'blur',
                    },
                ],
                ip: [
                    {
                        required: true,
                        message: '服务器ip不能为空',
                        trigger: 'blur',
                    },
                ],
                domain: [
                    {
                        required: true,
                        message: '服务器域名不能为空',
                        trigger: 'blur',
                    },
                ],
                secret: [
                    {
                        required: true,
                        message: '流媒体密钥不能为空',
                        trigger: 'blur',
                    },
                ],
                portHttp: [
                    {
                        required: true,
                        message: 'http端口不能为空',
                        trigger: 'blur',
                    },
                ],
                portHttps: [
                    {
                        required: true,
                        message: 'https端口不能为空',
                        trigger: 'blur',
                    },
                ],
                portRtmp: [
                    {
                        required: true,
                        message: 'rtmp端口不能为空',
                        trigger: 'blur',
                    },
                ],
                portRtsp: [
                    {
                        required: true,
                        message: 'rtsp端口不能为空',
                        trigger: 'blur',
                    },
                ],
                rtpPortRange: [
                    {
                        required: true,
                        message: 'rtp端口范围不能为空',
                        trigger: 'blur',
                    },
                ],
                delFlag: [
                    {
                        required: true,
                        message: '删除标志不能为空',
                        trigger: 'blur',
                    },
                ],
                createBy: [
                    {
                        required: true,
                        message: '创建者不能为空',
                        trigger: 'blur',
                    },
                ],
                createTime: [
                    {
                        required: true,
                        message: '创建时间不能为空',
                        trigger: 'blur',
                    },
                ],
            },
        };
    },
    created() {
        // 普通用户只能查看自己的通道
        if (this.$store.state.user.roles.indexOf('general') === -1) {
            this.isGeneralUser = false;
        }
        this.getList();
    },
    methods: {
        /** 查看设备操作 */
        handleViewDevice(serialNumber) {
            this.$router.push({
                path: '/iot/device',
                query: {
                    t: Date.now(),
                    sn: serialNumber,
                },
            });
        },
        /**选择产品 */
        selectProduct() {
            //this.open = false;
            this.$refs.productList.open = true;
            this.$refs.productList.getList();
        },
        /**获取选中的产品 */
        getProductData(product) {
            //this.open = true;
            this.createForm.productId = product.productId;
            this.createForm.productName = product.productName;
            this.createForm.tenantId = product.tenantId;
            this.createForm.tenantName = product.tenantName;
            this.$refs.createForm.clearValidate('productName');
            this.$forceUpdate(); // 强制更新视图
        },
        /** 行政区划改变 **/
        changeProvince(data) {
            if (data && data[0] != null && data[1] != null && data[2] != null) {
                const str = CodeToText[data[0]] + '/' + CodeToText[data[1]] + '/' + CodeToText[data[2]];
                this.createForm.citycode = str;
            }
        },
        /**获取设备详情*/
        getDeviceBySerialNumber(serialNumber) {
            this.openDevice = true;
            getDeviceBySerialNumber(serialNumber).then((response) => {
                this.device = response.data;
            });
        },
        /** 查询通道列表 */
        getList() {
            listChannel(this.queryParams).then((response) => {
                this.sipidList = response.rows;
                this.total = response.total;
                this.loading = false;
            });
        },
        // 取消按钮
        cancel() {
            this.open = false;
            this.reset();
        },
        // 表单重置
        reset() {
            this.createForm = {
                id: null,
                deviceSipId: null,
                channelSipId: null,
                status: 0,
                registertime: null,
                createBy: null,
                createTime: null,
                updateBy: null,
                updateTime: null,
                remark: null,
                createNum: 1,
            };
            this.resetForm('createForm');
        },
        /** 搜索按钮操作 */
        handleQuery() {
            this.loading = true;
            this.queryParams.pageNum = 1;
            this.getList();
        },
        /** 重置按钮操作 */
        resetQuery() {
            this.resetForm('queryForm');
            this.handleQuery();
        },
        // 多选框选中数据
        handleSelectionChange(selection) {
            this.ids = selection.map((item) => item.id);
            this.multiple = !selection.length;
        },
        /** 批量新增按钮操作 */
        handleAdd() {
            this.reset();
            this.open = true;
            this.title = '生成设备通道';
        },
        /** 修改按钮操作 */
        handleUpdate(row) {
            this.reset();
            const id = row.id || this.ids;
            console.log(row);
            getChannel(id).then((response) => {
                this.createForm = response.data;
                this.open = true;
                this.title = '修改产品分类';
            });
        },
        /** 提交按钮 */
        submitForm() {
            this.$refs['createForm'].validate((valid) => {
                if (valid) {
                    this.createForm.deviceSipId = this.createForm.city[2] + '0000' + this.createForm.deviceType + '0';
                    this.createForm.channelSipId = this.createForm.city[2] + '0000' + this.createForm.channelType + '0';
                    addChannel(this.createForm.createNum, this.createForm).then((response) => {
                        this.$modal.msgSuccess('新增成功');
                        this.open = false;
                        this.getList();
                    });
                }
            });
        },
        /** 删除按钮操作 */
        handleDelete(row) {
            const sipIds = row.id || this.ids;
            this.$modal
                .confirm('是否确认删除ID为"' + sipIds + '"的数据项？')
                .then(function () {
                    return delChannel(sipIds);
                })
                .then(() => {
                    this.getList();
                    this.$modal.msgSuccess('删除成功');
                })
                .catch(() => {});
        },
        //禁用有绑定设备的复选框,status:1=未使用，2=已使用
        selectable(row) {
            if (row.status == 2 || this.isGeneralUser) {
                return false;
            }
            return true;
        },
        //表格增加复制功能
        celldblclick(row, column, cell, event) {
            this.$copyText(row[column.property]).then(
                (e) => {
                    this.onCopy();
                },
                function (e) {
                    this.onError();
                }
            );
        },
        onCopy() {
            this.$notify({
                title: '成功',
                message: '复制成功！',
                type: 'success',
                offset: 50,
                duration: 2000,
            });
        },
        onError() {
            this.$notify({
                title: '失败',
                message: '复制失败！',
                type: 'error',
                offset: 50,
                duration: 2000,
            });
        },
    },
};
</script>
